<template>
  <div class="main">
    <div class="title">
      <a class="active" href="/login">登录</a>
      <span>·</span>
      <a href="/register">注册</a>
    </div>
    <div class="sign-up-container">
      <el-form ref="userForm" :model="user">

        <el-form-item class="input-prepend restyle" prop="mobile"
                      :rules="[{ required: true, message: '请输入手机号码', trigger: 'blur' },{validator: checkPhone, trigger: 'blur'}]">
          <div>
            <el-input type="text" placeholder="手机号" v-model="user.mobile" @keyup.enter.native="submitLogin()"/>
            <i class="iconfont icon-phone"/>
          </div>
        </el-form-item>

        <el-form-item class="input-prepend" prop="password"
                      :rules="[{ required: true, message: '请输入密码', trigger: 'blur' }]">
          <div>
            <el-input type="password" placeholder="密码" v-model="user.password" @keyup.enter.native="submitLogin()"/>
            <i class="iconfont icon-password"/>
          </div>
        </el-form-item>

        <div class="btn">
          <input type="button" class="sign-in-button" value="登录" @click="submitLogin">
        </div>
      </el-form>
      <!-- 更多登录方式 -->
      <div class="more-sign">
        <h6>社交帐号登录</h6>
        <ul>
          <li><a id="weixin" class="weixin" target="_blank"
                 href="http://localhost:9001/api/ucenter/wx/loginByWx"><i class="iconfont icon-weixin"/></a>
          </li>
          <li><a id="qq" class="qq" target="_blank" href="#"><i class="iconfont icon-qq"/></a></li>
        </ul>
      </div>
    </div>

  </div>
</template>

<script>
  import '~/assets/css/sign.css'
  import '~/assets/css/iconfont.css'
  import cookie from 'js-cookie'
  import loginApi from '@/api/login'

  export default {
    layout: 'sign',

    data() {
      return {
        user: {
          mobile: '',
          password: ''
        },
        loginInfo: {}
      }
    },

    methods: {
      submitLogin() {
        loginApi.submitLogin(this.user).then(response => {
          // 把token放入cookie 1. 名称 2. 值 3. cookie作用范围
          cookie.set("login_token", response.data.data.token, {domain: 'localhost'})
          // 调用接口根据token查询
          loginApi.getLoginInfo().then(response => {
            this.loginInfo = response.data.data.userInfo
            // 把用户信息放进去
            cookie.set("user_center", this.loginInfo, {domain: 'localhost'})
            // 跳至主页面
            this.$router.push('/')
          }).catch(() => {
            this.$message({
              type: 'error',
              message: '账号或密码有误,请重新输入'
            })
            this.user.password = ''
          })
        })
      },
      checkPhone(rule, value, callback) {
        //debugger
        if (!(/^1[34578]\d{9}$/.test(value))) {
          return callback(new Error('手机号码格式不正确'))
        }
        return callback()
      }
    }
  }
</script>
<style>
  .el-form-item__error {
    z-index: 9999999;
  }
</style>
